

## Conjunto de instruções do CESAR16 e CESAR16i

| Instruções de uso geral     |           |                              |  |  |  |  |  |
|-----------------------------|-----------|------------------------------|--|--|--|--|--|
| H Código Instrução Operação |           |                              |  |  |  |  |  |
| 0x                          | 0000 xxxx | 00 xxxx NOP Nenhuma operação |  |  |  |  |  |
| Fx                          |           |                              |  |  |  |  |  |

| Instruções sobre os códigos de condição (flags) |           |             |                      |  |  |  |  |
|-------------------------------------------------|-----------|-------------|----------------------|--|--|--|--|
| H Código Instrução Operação                     |           |             |                      |  |  |  |  |
| 1?                                              | 0001 nzvc | CCC<br>NZVC | Clear Condition Code |  |  |  |  |
| 2?                                              | 0010 nzvc | SCC NZVC    | Set Condition Code   |  |  |  |  |

| Instr | Instruções de controle de fluxo |          |             |                                               |                 |  |  |  |
|-------|---------------------------------|----------|-------------|-----------------------------------------------|-----------------|--|--|--|
| Н     | Código                          | Destino  | Instrução   | Operação                                      | Condição        |  |  |  |
| 30    | 0011 0000                       | dd8      | BR dd8      | R7 ← R7 + dd8                                 | sempre          |  |  |  |
| 31    | 0011 0001                       | dd8      | BNE dd8     | if (NotEqual) then R7 ← R7 + dd8              | z = 0           |  |  |  |
| 32    | 0011 0010                       | dd8      | BEQ dd8     | if (Equal) then R7 ← R7 + dd8                 | z = 1           |  |  |  |
| 33    | 0011 0011                       | dd8      | BPL dd8     | if (Plus) then R7 ← R7 + dd8                  | n = 0           |  |  |  |
| 34    | 0011 0100                       | dd8      | BMI dd8     | if (Minus) then R7 ← R7 + dd8                 | n = 1           |  |  |  |
| 35    | 0011 0101                       | dd8      | BVC dd8     | if (Overflow Clear) then R7 ← R7 + dd8        | v = 0           |  |  |  |
| 36    | 0011 0110                       | dd8      | BVS dd8     | if (Overflow Set) then R7 ← R7 + dd8          | v = 1           |  |  |  |
| 37    | 0011 0111                       | dd8      | BCC dd8     | if (Carry Clear) then R7 ← R7 + dd8           | c = 0           |  |  |  |
| 38    | 0011 1000                       | dd8      | BCS dd8     | if (Carry Set) then R7 ← R7 + dd8             | c = 1           |  |  |  |
| 39    | 0011 1001                       | dd8      | BGE dd8     | (≥) if (Greater or Equal) then R7 ← R7 + dd8  | n = v           |  |  |  |
| 3A    | 0011 1010                       | dd8      | BLT dd8     | (<) if (Less Than) then R7 ← R7 + dd8         | n <> v          |  |  |  |
| 3B    | 0011 1011                       | dd8      | BGT dd8     | (>) if (Greater Than) then R7 ← R7 + dd8      | n = v and z = 0 |  |  |  |
| 3C    | 0011 1100                       | dd8      | BLE dd8     | (≤) if (Less or Equal) then R7 ← R7 + dd8     | n <> v or z = 1 |  |  |  |
| 3D    | 0011 1101                       | dd8      | BHI dd8     | ( x  >) if (Higher) then R7 ← R7 + dd8        | c = 0 and z = 0 |  |  |  |
| 3E    | 0011 1110                       | dd8      | BLS dd8     | ( x  ≤) if (Lower or Same) then R7 ← R7 + dd8 | c = 1 or z = 1  |  |  |  |
| 4x    | 0100 xxxx                       | xxmmmrrr | JMP end     | R7 ← end                                      | sempre          |  |  |  |
| 5?    | 0101 xrrr                       | dd8      | SOB reg,dd8 | reg ← reg - 1; if (reg<>0) then R7 ← R7-dd8   | Ri - 1 <> 0     |  |  |  |
| 6?    | 0110 xrrr                       | xxmmmrrr | JSR reg,end | Pilha ← reg; reg ← R7; R7 ← end               | sempre          |  |  |  |
| 7?    | 0111 xrrr                       | -        | RTS reg     | R7 ← reg; reg ← Pilha                         | sempre          |  |  |  |

| Instruções com 2 operandos |           |           |                      |                   |   |   | Flags |        |  |  |
|----------------------------|-----------|-----------|----------------------|-------------------|---|---|-------|--------|--|--|
| Н                          | Código    | Operandos | N                    | Z                 | V | С |       |        |  |  |
| 9?                         | 1001 mmmr | rrmmmrrr  | MOV src_end, dst_end | dst ← src         | t | t | 0     | -      |  |  |
| A?                         | 1010 mmmr | rrmmmrrr  | ADD src_end, dst_end | dst ← dst + src   | t | t | t     | t      |  |  |
| B?                         | 1011 mmmr | rrmmmrrr  | SUB src_end, dst_end | dst ← dst - src   | t | t | t     | not(t) |  |  |
| C?                         | 1100 mmmr | rrmmmrrr  | CMP src_end, dst_end | src - dst         | t | t | t     | not(t) |  |  |
| D?                         | 1101 mmmr | rrmmmrrr  | AND src_end, dst_end | dst ← dst AND src | t | t | 0     | -      |  |  |
| E?                         | 1110 mmmr | rrmmmrrr  | OR src_end, dst_end  | dst ← dst OR src  | t | t | 0     | -      |  |  |

| Instr | Instruções com 1 operando |          |           |                                         |   | Flags |     |        |  |
|-------|---------------------------|----------|-----------|-----------------------------------------|---|-------|-----|--------|--|
| Н     | Código                    | Operando | Instrução | Operação                                | N | Z     | V   | С      |  |
| 80    | 1000 0000                 | xxmmmrrr | CLR op    | op ← 0                                  | 0 | 1     | 0   | 0      |  |
| 81    | 1000 0001                 | xxmmmrrr | NOT op    | op ← NOT op                             | t | t     | 0   | 1      |  |
| 82    | 1000 0010                 | xxmmmrrr | INC op    | op ← op + 1                             | t | t     | t   | t      |  |
| 83    | 1000 0011                 | xxmmmrrr | DEC op    | op ← op - 1                             | t | t     | t   | not(t) |  |
| 84    | 1000 0100                 | xxmmmrrr | NEG op    | op ← - op                               | t | t     | t   | not(t) |  |
| 85    | 1000 0101                 | xxmmmrrr | TST op    | op ← op                                 | t | t     | 0   | 0      |  |
| 86    | 1000 0110                 | xxmmmrrr | ROR op    | Rotate "op" one bit right through carry | t | t     | xor | lsb    |  |
| 87    | 1000 0111                 | xxmmmrrr | ROL op    | Rotate "op" one bit left through carry  | t | t     | xor | msb    |  |
| 88    | 1000 1000                 | xxmmmrrr | ASR op    | Shift "op" one bit right                | t | t     | xor | lsb    |  |
| 89    | 1000 1001                 | xxmmmrrr | ASL op    | Shift "op" one bit left                 | t | t     | xor | msb    |  |
| 8A    | 1000 1010                 | xxmmmrrr | ADC op    | op ← op + c (carry)                     | t | t     | t   | t      |  |
| 8B    | 1000 1011                 | xxmmmrrr | SBC op    | op ← op -c (carry)                      | t | t     | t   | t      |  |

rrr ou reg - indica um dos 8 registradores (R0 a R7);

mmm - indica um dos 8 modos de endereçamento;

x - indica que o bit não importa para a execução da instrução;

dd8 - representa um endereço de 8 bits;

t - indica que o código de condição é testado pela unidade de controle e ajustado de acordo;

not(t) - para o carry indica que o valor carregado é o borrow-out;

xor - para o overflow indica que este é carregado com o "ou exclusivo" entre os bits N e C após a execução da instrução;

lsb - é o bit menos significativo do operando (antes da execução);

msb - é o bit mais significativo do operando (antes da execução);



| Modos de endereçamento (mmm) |                           |            |                        |  |  |  |  |  |
|------------------------------|---------------------------|------------|------------------------|--|--|--|--|--|
| Código                       | Nome                      | Símbolo    | Operação               |  |  |  |  |  |
| 000                          | Registrador               | Ri         | Ri                     |  |  |  |  |  |
| 001                          | Reg. Pós-incrementado     | (Ri)+      | MEM(Ri); Ri + = 2      |  |  |  |  |  |
| 010                          | Reg. Pré-decrementado     | -(Ri)      | Ri - = 2; MEM(Ri)      |  |  |  |  |  |
| 011                          | Indexado                  | dd16(Ri)   | MEM(dd16+Ri)           |  |  |  |  |  |
| 100                          | Reg. Indireto             | (Ri)       | MEM(Ri)                |  |  |  |  |  |
| 101                          | Pós-incrementado Indireto | ((Ri)+)    | MEM(MEM(Ri)); Ri + = 2 |  |  |  |  |  |
| 110                          | Pré-decrementado Indireto | (-(Ri))    | Ri - = 2; MEM(MEM(Ri)) |  |  |  |  |  |
| 111                          | Indexado Indireto         | (dd16(Ri)) | MEM(MEM(dd16+Ri))      |  |  |  |  |  |

| Registradores (rrr) |         |  |  |  |  |
|---------------------|---------|--|--|--|--|
| Código              | Reg.    |  |  |  |  |
| 000                 | R0      |  |  |  |  |
| 001                 | R1      |  |  |  |  |
| 010                 | R2      |  |  |  |  |
| 011                 | R3      |  |  |  |  |
| 100                 | R4      |  |  |  |  |
| 101                 | R5      |  |  |  |  |
| 110                 | R6 (SP) |  |  |  |  |
| 111                 | R7 (PC) |  |  |  |  |

| Modos de endereçamento derivados utilizando o R7 (PC) |                   |           |             |                        |  |  |  |  |  |
|-------------------------------------------------------|-------------------|-----------|-------------|------------------------|--|--|--|--|--|
| Código                                                | Nome              | Instrução | Simbolo     | Operação               |  |  |  |  |  |
| xx001 111                                             | Imediato          | #dd16     | (R7) + dd16 | MEM(R7); R7 + = 2      |  |  |  |  |  |
| xx101 111                                             | Absoluto          | dd16      | ((R7)+)dd16 | MEM(MEM(R7)); R7 + = 2 |  |  |  |  |  |
| xx011 111                                             | Relativo          | -         | dd8(R7)     | MEM(dd8 + R7)          |  |  |  |  |  |
| xx111 111                                             | Relativo Indireto | -         | (dd8(R7))   | MEM(MEM(dd8 + R7))     |  |  |  |  |  |

| Dec.  | Hex. | Endereços Especiais                                                                                                                                                                                                                                            |
|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 65408 | FF80 | Endereço sugerido para o fundo da stack                                                                                                                                                                                                                        |
| 65469 | FFBD | 31 palavras reservadas para uso futuro                                                                                                                                                                                                                         |
| 65470 | FFBE | IVET - Primeiro byte do "vetor de interrupção" - endereço da ISR (Interrupt Service Routine)                                                                                                                                                                   |
| 65471 | FFBF | IVET - Segundo byte do "vetor de interrupção" - endereço da ISR                                                                                                                                                                                                |
| 65472 | FFC0 | Início da área de acesso em 8 bits                                                                                                                                                                                                                             |
| 65473 | FFC1 | 23 bytes reservados para uso futuro                                                                                                                                                                                                                            |
| 65495 | FFD7 | TIMDT - Timer base time                                                                                                                                                                                                                                        |
| 65496 | FFD8 | INTS - Interrupt Status - Monitoramento do estado das interrupções Bit 7: IP - Interrupt Pending - em geral só deve estar ligado quando executando a ISR Bit 1: IPStec - Interrupt Pending Source 1: Teclado Bit 0: IPStim - Interrupt Pending Source 0: Timer |
| 65497 | FFD9 | INTE - Interrupt Enable - Controle de habilitação das interrupções Bit 7: IE - Interrupt Enable Bit 1: IEStec - Interrupt Enable Source 1: Teclado Bit 0: IEStim - Interrupt Enable Source 0: Timer                                                            |
| 65498 | FFDA | TECST - Se o conteúdo deste endereço de memória for H80 então existe tecla disponível                                                                                                                                                                          |
| 65499 | FFDB | TECDT - Dado do Teclado - Endereço a ser lido caso exista uma tecla disponível                                                                                                                                                                                 |
| 65500 | FFDC | Início do endereçamento dos 36 bytes do visor                                                                                                                                                                                                                  |
| 65535 | FFFF | Fim do endereçamento do visor e fim da memória                                                                                                                                                                                                                 |

|     | Tabela ASCII |      |      |      |          |      |      |      |      |  |
|-----|--------------|------|------|------|----------|------|------|------|------|--|
|     |              | H0?  | H1?  | H2?  | H3?      | H4?  | H5?  | H6?  | H7?  |  |
|     |              | x000 | x001 | x010 | x011     | x100 | x101 | x110 | x111 |  |
| H?0 | 0000         | null | dle  |      | 0        | @    | Р    | `    | р    |  |
| H?1 | 0001         | soh  | dc1  | !    | 1        | Α    | Q    | а    | q    |  |
| H?2 | 0010         | stx  | dc2  | 66   | 2        | В    | R    | b    | r    |  |
| H?3 | 0011         | etx  | dc3  | #    | 3        | С    | S    | С    | s    |  |
| H?4 | 0100         | eot  | dc4  | \$   | 4        | D    | Т    | d    | t    |  |
| H?5 | 0101         | enq  | nak  | %    | 5        | Е    | U    | е    | u    |  |
| H?6 | 0110         | ack  | syn  | &    | 6        | F    | V    | f    | ٧    |  |
| H?7 | 0111         | bell | etb  | "    | 7        | G    | W    | g    | W    |  |
| H?8 | 1000         | bsp  | can  | (    | 8        | Н    | Χ    | h    | Х    |  |
| H?9 | 1001         | ht   | em   | )    | 9        |      | Υ    | i    | у    |  |
| H?A | 1010         | lf   | sub  | *    | :        | J    | Z    | j    | Z    |  |
| H?B | 1011         | vt   | esc  | +    | ;        | K    | ]    | k    | {    |  |
| H?C | 1100         | ff   | fs   | ,    | <b>'</b> | L    | \    | I    |      |  |
| H?D | 1101         | cr   | gs   | -    | =        | М    | ]    | m    | }    |  |
| H?E | 1110         | so   | rs   |      | >        | N    | ۸    | n    | ~    |  |
| H?F | 1111         | si   | us   | 1    | ?        | 0    |      | 0    | del  |  |

inscesar.txt · Last modified: 2023/03/20 02:20 (Aluno Paulo Cauê Krüger Costa - external edit)